Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[0010] Clarify behavior of vk::aliased_pointer on vk::BufferPointer #95

Merged
merged 4 commits into from
Nov 8, 2023

Conversation

greg-lunarg
Copy link
Contributor

Specifically, clarify interaction with default (restrict) BufferPointer.

Fixes #87.

Specifically, clarify interaction with default (restrict) BufferPointer.

Fixes microsoft#87.
@llvm-beanz llvm-beanz requested a review from s-perron September 14, 2023 17:15
@@ -184,7 +184,7 @@ Applying HLSL semantic annotations to objects of type vk::BufferPointer is disal

By default, buffer pointers are assumed to be restrict pointers as defined by the C99 standard.

An attribute vk::aliased_pointer can be attached to a variable, function parameter or a block member of buffer pointer type. It is assumed that the pointee of an object with this attribute can overlap with the pointee of any other object with this attribute.
An attribute vk::aliased_pointer can be attached to a variable, function parameter or a block member of BufferPointer type. It ie assumed that the pointee of a BufferPointer with this attribute can overlap with the pointee of any other BufferPointer with this attribute. This also means that the pointee of a BufferPointer with this attribute does not overlap with the pointee of a default (restrict) BufferPointer.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks like you introduced a typo "It ie assumed ...".

@s-perron s-perron self-requested a review September 14, 2023 17:46
Copy link
Collaborator

@s-perron s-perron left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How does this fix #87?

@@ -184,7 +184,7 @@ Applying HLSL semantic annotations to objects of type vk::BufferPointer is disal

By default, buffer pointers are assumed to be restrict pointers as defined by the C99 standard.

An attribute vk::aliased_pointer can be attached to a variable, function parameter or a block member of buffer pointer type. It is assumed that the pointee of an object with this attribute can overlap with the pointee of any other object with this attribute.
An attribute vk::aliased_pointer can be attached to a variable, function parameter or a block member of BufferPointer type. It ie assumed that the pointee of a BufferPointer with this attribute can overlap with the pointee of any other BufferPointer with this attribute. This also means that the pointee of a BufferPointer with this attribute does not overlap with the pointee of a default (restrict) BufferPointer.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The meaning of the restrict attribute only applies to a scope.

For example the following is allowed in C:

int foo(restrict int* p) {
  return *p;
}

int func(int * p) {
  return foo(p); // implicit cast from "aliased" to "restrict".
}

The extra sentence you added is not true. An aliased pointer and restrict pointer can point to overlapping storage as long as the aliased pointer is not used during the lifetime of the restrict pointer.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree this PR does not necessarily address #87. I will attempt to redress that.

I am not sure I agree that my "extra" statement above is false, although perhaps underspecified. My statement above assumes that the two pointers in question have overlapping scopes. If they don't have overlapping scopes, than their overlapping memory is moot, it seems to me. But I will add that the pointers have overlapping scopes to clarify.

@greg-lunarg
Copy link
Contributor Author

I have added clarifying text for alias casting. I have also added an example.

@greg-lunarg
Copy link
Contributor Author

@s-perron Please review

Copy link
Collaborator

@s-perron s-perron left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems fine.

@s-perron s-perron requested a review from llvm-beanz November 2, 2023 14:51
@s-perron
Copy link
Collaborator

s-perron commented Nov 2, 2023

@llvm-beanz Can you review this for the second approval.

@llvm-beanz llvm-beanz merged commit 70572e0 into microsoft:main Nov 8, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[0010] Define behavior of casting between aliased & non-aliased pointers
3 participants